/*
 * Copyright (C) 2018 yixun All Rights Reserved.
 * 
 * MarketingAccountServiceImpl.java
 */
package com.yixun.qfbao.service.impl;

import com.yixun.common.page.Page;
import com.yixun.qfbao.mapper.MarketingAccountMapper;
import com.yixun.qfbao.mapper.MarketingAccountUseinfoMapper;
import com.yixun.qfbao.model.MarketingAccount;
import com.yixun.qfbao.model.dto.MarketingAccountDto;
import com.yixun.qfbao.service.MarketingAccountService;
import com.yixun.qfbao.xf.mapper.PremisesMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.Calendar;
import java.util.List;


/**
 * [文件名称]<br>
 * MarketingAccountServiceImpl.java<br>
 * <br>
 * [文件描述]<br>
 * 营销号 service interface impl<br>
 * <br>
 * [修改记录]<br>
 * 2018-05-31 11:49:10 创建 陶俊代码生成器<br>
 * 
 * @author 陶俊代码生成器
 * @version 1.00
 */
@Service("marketingAccountService")
public class MarketingAccountServiceImpl implements MarketingAccountService {
	
	@Autowired
	private MarketingAccountMapper mapper;
	@Autowired
	private PremisesMapper premisesMapper;
	@Autowired
	private MarketingAccountUseinfoMapper marketingAccountUseinfoMapper;
	
	/**
	 * @param entity 搜索条件
	 * @param begin 分页开始行数[不包含]
	 * @param end 分页结束行数[包含]
	 * @return 分页记录
	 */
	@Transactional(readOnly = true)
	public Page<MarketingAccount> getPageModel(MarketingAccountDto entity,int begin,int end){
		Integer total = mapper.count(entity);
		List<MarketingAccount> rows = mapper.list(entity,begin,end);
	    Page<MarketingAccount> msr = new Page<MarketingAccount>(total, rows);
		return msr;
	}

	/**
	 * 查询列表
	 * @param entity 搜索条件
	 * @return 分页记录
	 */
	public List<MarketingAccount> selectListByDto(MarketingAccountDto entity){
		return mapper.selectListByDto(entity);
	}
	
	/**
	 * 查询单个
	 * @param entity 搜索条件
	 * @return 分页记录
	 */
	public MarketingAccount selectByDto(MarketingAccountDto entity){
		return mapper.selectByDto(entity);
	}
	
	/**
	 * @param entity 搜索条件
	 * @return 分页记录
	 */
	public MarketingAccount selectById(Long id){
		if(id!=null){
			return mapper.selectById(id);
		}
		return null;
	}
	/**
	 * @param entity 新增记录的详细信息
	 * @return 新增行数
	 */
	public MarketingAccountDto create(MarketingAccountDto entity) {
		entity.setCreateTime(Calendar.getInstance().getTime());
		mapper.add(entity);
		return entity;
	}

	/**
	 * @param entity 更新记录的详细信息
	 * @return 更新行数
	 */
	public int update(MarketingAccountDto entity) {
		entity.setUpdateTime(Calendar.getInstance().getTime());
		return mapper.edit(entity);
	}
    
	/**
	 * @param entity 待删除的记录信息
	 * @return 删除行数
	 */
	public int destroy(MarketingAccountDto entity) {
		return mapper.del(entity);
	}
	
	/**
	 * @param entity 新增或更新
	 * @return 新增行数
	 */
	public int saveOrUpdate(MarketingAccountDto entity) {
		if(entity!=null&&entity.getId()!=null){
			return update(entity);
		}else{
			create(entity);
			return 1;
		}
	}
	
	/**
	 * @param entity 根据pojo搜索如果主键为空则返回它本身
	 * @return 一行记录或本身
	 */
	@Override
	public MarketingAccount selectBy(MarketingAccount entity) {
		if(entity!=null&&entity.getId()!=null){
			return mapper.selectById(entity.getId());
		}
		return entity;
	}
}
